import { createApp } from 'vue'

import Cookies from 'js-cookie'

import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
import locale from 'element-plus/es/locale/lang/zh-cn'

import '@/assets/styles/index.scss' // global css
import '@arco-design/web-vue/dist/arco.less';
// import '@pickmall/ui-v3-components/dist/style.css';


import App from './App'
import store from './store'
import router from './router'
import directive from './directive' // directive
import { autoAnimatePlugin } from '@formkit/auto-animate/vue';
// 注册指令
import plugins from './plugins' // plugins
import { download } from '@/utils/request'

// svg图标
import 'virtual:svg-icons-register'
import SvgIcon from '@/components/SvgIcon'
import elementIcons from '@/components/SvgIcon/svgicon'
import ArcoVueIcon from '@arco-design/web-vue/es/icon';

import './permission' // permission control

import { useDict } from '@/utils/dict'
import { parseTime, resetForm, addDateRange, handleTree, selectDictLabel, selectDictLabels, unitPrice } from '@/utils/ruoyi'
import { ColorPicker as TColorPicker } from 'tdesign-vue-next';
import 'uno.css';
// 引入TDesign的内容用于 colorpicker guide 等
import 'tdesign-vue-next/es/style/index.css';
// 分页组件
import Pagination from '@/components/Pagination'
// 自定义表格工具组件
import RightToolbar from '@/components/RightToolbar'
// 富文本组件
import Editor from "@/components/Editor"
import wangEditor from "@/components/wangEditor"
// 文件上传组件
import FileUpload from "@/components/FileUpload"
// 图片上传组件
import ImageUpload from "@/components/ImageUpload"
// 图片预览组件
import ImagePreview from "@/components/ImagePreview"
// 自定义树选择组件
import TreeSelect from '@/components/TreeSelect'
// 字典标签组件
import DictTag from '@/components/DictTag'

const app = createApp(App)
app.config.globalProperties.$openWindow = (path) => {
  const routerUrl = router.resolve(path);
  window.open(routerUrl.href, '_blank');
};

// 全局方法挂载
app.config.globalProperties.useDict = useDict
app.config.globalProperties.download = download
app.config.globalProperties.parseTime = parseTime
app.config.globalProperties.resetForm = resetForm
app.config.globalProperties.handleTree = handleTree
app.config.globalProperties.addDateRange = addDateRange
app.config.globalProperties.selectDictLabel = selectDictLabel
app.config.globalProperties.selectDictLabels = selectDictLabels
app.config.globalProperties.unitPrice = unitPrice

// 全局组件挂载
app.component('DictTag', DictTag)
app.component('Pagination', Pagination)
app.component('TreeSelect', TreeSelect)
app.component('FileUpload', FileUpload)
app.component('ImageUpload', ImageUpload)
app.component('ImagePreview', ImagePreview)
app.component('RightToolbar', RightToolbar)
app.component('Editor', Editor)
app.component('wangEditor', wangEditor)

app.use(autoAnimatePlugin);
app.use(router)
app.use(store)
app.use(plugins)
app.use(elementIcons)
app.use(ArcoVueIcon)
app.component('svg-icon', SvgIcon)
app.use(TColorPicker)
directive(app)

// 使用element-plus 并且设置全局的大小
// app.use(ElementPlus, {
//   locale: locale,
//   // 支持 large、default、small
//   size: Cookies.get('size') || 'default'
// })

app.mount('#app')
